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(54) Method and apparatus for multi-channel acoustic echo cancellation 



(57) In a multi-channel acoustic echo cancellation, 
received signals in a plurality of channels are radiated 
as acoustic signals by a plurality of loudspeakers, 
received signal vectors in these channels are combined 
into a combined vector and a rearranged received sig- 
nal vector in the case of at least two channels being 
exchanged is generated. By inputting the combined 
received signal vector into an echo replica generating 
part which simulates echo paths from the loudspeakers 
to at least one microphone, an echo replica is gener- 

FIG. 7 



ated. The echo replica is subtracted from an echo out- 
put from the microphone to obtain a residual echo. 
Based on the relationship between the received signal 
vector and the corresponding residual echo and 
between the rearranged received signal vector and the 
corresponding approximated residual echo, an adjust- 
ment vector is obtained which is used to adjust the esti- 
mated echo path vector representing an impulse 
response of the echo replica generating part. 
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Description 

BACKGROUND OF THE INVENTION 

The present invention relates to a method and apparatus for mutti-channel acoustic echo cancellation which cancel 
room echoes which would otherwise cause howling and present psycho-acoustic problems in a teleconference system 
with a multi-receive-channel system. 

There have been proposed echo cancellers with a view to offering a hands-free telecommunication system which 
is excellent in double-talk performance and is almost free from the influence of echoes. 

A description will be given first, with reference to Fig. 1 , of a conventional method and apparatus for one-channel 
acoustic echo cancellation. In the hands-free telecommunication, there are two cases where the received signal pro- 
vided at a received signal input terminal 1 1 is reproduced intact by a loudspeaker 12 and where the received signal is 
reproduced by the loudspeaker 12 after being subjected to some processing by a received signal processing part 13 
which automatically controls its gain in accordance with the amplitude, power or the like of the received signal. On this 
account, the received signal x^k) mentioned herein is not limited specifically to the received signal itself from the per- 
son talking at the other end but also indicates the processed received signal when the received signal processing part 
13 is provided, k represents a discrete time index. An echo canceller 14 cancels an echo y^k) which is produced when 
the received signal x^k) from the loudspeaker 12 is picked up by a microphone 16 after propagating over an echo path 
15. The echo y^k) can be modeled as a signal which can be obtained by the following convolution with the impulse 
response of the echo path 15 at time k represented by h-, ^M): 

y 1 (k) = Lh 11 (k,n)x 1 (k-n) (1) 

where Z indicates the summation from n=0 to L-1 , L being the number of taps, which is a constant preset corresponding 
to the reverberation time of the echo path 15. In the first place, received signals x^k) at times back to L-1 are stored in 
a received signal storage/vector generating part 17. The received signals thus stored are output as a received signal 
vector x^k), which is given as follows: 

Xl (k) - [x 1 (k),x 1 (k-l),-,x 1 (k-L+l)] T (2) 



where (*) T indicates a transpose of vector. An echo replica generating part 18 calculates the inner product of the 
received signal vector x^k) of Eq. (2) and an echo replica vector h^k) obtainable from an echo path estimating part 
19 as follows: 

?,(k) -fil.Wx.ik) (3) 

As a result, an echo replica y^k) is generated. This inner product calculation is equivalent to such a convolution as Eq. 
(1). The echo path estimating part 19 generates the echo replica vector hn(k) that is used in the echo replica gener- 
ating part 18. The most common algorithm for this echo path estimation is the NLMS (Normalized Least Mean Squares) 
algorithm. With the NLMS algorithm, the received signal vector x^k) at time k and a residual echo e^k), i.e. the follow- 
ing error obtained by subtracting the echo replica from the output of the microphone 16 with a subtracter 21 , 

e 1 (k) = y 1 (kH 1 (k) (4) 
are used to calculate an estimated echo path vector h^fk+l) which is used at time k+1, by the following equation: 

fi„(k+l) = SntkJ + ae^klx^kj/lx^kJx^k)} (5) 

where a is called a step size parameter, which is used to adjust adaptation within the range of 0<a<2. By repeating the 
above processing, the echo path estimating part 19 is allowed to gradually converge the estimated echo path vector 
h^fk) toward an echo path vector hn(k) which has. as its elements, a time sequence of impulse responses h n (k,n) of 
the true echo path 15 given by the following equation: 
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h M (k) = [h„(k,0),h 11 (k,l), -,h M (k.L-l)] T (6) 

5 As the result of this, the residual echo e<j(k) given by Eq. (4) can be reduced. 

In general, a teleconference system of the type having an N£2)-receive-channel system and an M(^1) -pickup- 
channel system employs, for echo cancellation, such a configuration as shown in Rg. 2. That is, an echo cancellation 

system 23 is implemented in which N-channel echo cancellers 22 1( 22 2 22 M for processing N-inputs-one-output 

time sequence signals are each connected between all the N channels of the receive (loudspeaker) side and one chan- 

10 nel of the pickup (microphone) side. In this instance, the echo cancellation system 23 has a total of N x M echo paths 

1 5 nm (where isnsN and IsrrtsM). The N-channel echo cancellers 22 1t 22 2 22 M , which are each connected between 

all of the N channels of the receive side and one channel of the pickup side, have such a configuration as depicted in 
Fig. 3, which is an extended version of the configuration of the echo canceller 14 shown in Rg. 1. This is described in 
detail, for example, in B. Widrow and S.D. Stearns, "Adaptive Signal Processing," Prince-Hall, Inc., pp. 198-200 (1985). 

is Now, consider the N-channel echo canceller 22 m having its pickup side connected to an m-th (where l^msM) pickup 
channel. The echo y m (k) which is picked up by the m-th channel microphone 16m is created by adding together respec- 
tive received signals of all receive channels at the pickup side after propagation over respective echo paths 15 1m 
through 15n m . Hence, it is necessary to devise how to make the echo path estimation by evaluating only one residual 
echo e m (k) in common to all the channels. In the first place, for the received signal x^k) of each channel, the following 

20 received signal vectors are generated in the received signal storage/vector generating parts 17 1t 17 2 , .... 17 N : 

Xl (k) - [x^kJ.x^k-D.-.x^k-L,*!)] 1 (7) 



25 X 2 



30 



35 



45 



55 



,(k) - [x 2 (k),x 2 (k-l),-,x l (k-L 1 + l)] T (8) 



x N (k) - [x N (k),x N (k-l),-,x N (k-L N+ l)] T (9) 

where L 1 , L2, .... Ln are numbers of taps, which are constants preset in correspondence with the reverberation times of 
the echo paths 15 1m , 152 m , 15 Nm . The vectors thus generated are combined in vector combining part 24 as follows: 

x(k) = [x] (k), x] (k) xl (k)] T (10) 



Also in the echo path estimating part 19 m , estimated echo path vectors h 1m (k), h 2m (k), • • • , h Nm (k), which are used 
to simulate N echo paths between the respective receive channel and the m-th pickup channel, are combined as fol- 
40 lows: 

A f>M /\T AT IT 

h m (k) = [ h lm (k), h 2m (k) h Nm (k)J (11) 



In the case of using the NLSM algorithm, the updating of the combined estimated echo path vector h m (k) is done as 
follows: 

so h m (k+l)= hm(k)+ae m (k)x(k)/{x T (k)x(k)} (12) 

In the echo replica generating part 18 m , an echo replica y m (k) for the echo y m (k) picked up in the m-th pickup channel 
by the following inner product calculation: 



y m (k) = hl(k)x(k) (13) 
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By combining the vectors in the respective channels into one vector, the flow of basic processing becomes the same as 
in the one-channel echo canceller of Fig. 1 . 

Of the shortcomings of the conventional echo cancellation system for application to the teleconference system 
composed of an N-receive-channel system and an M-pickup-channel system, the shortcoming that the present inven- 
tion is to solve will be described with respect to a concrete example. 

In the application of the conventional echo cancellation system to a two-channel stereo teleconference system 
which sends and receives signals between points A and B over two channels as shown in Fig. 4, there arises a problem 
that each time the speaker at the point A moves or changes, acoustic echoes from the point B by the speech at the point 
A increases even if the echo paths on the part of the point B remain unchanged. This problem is created by an incorrect 
echo path estimation in the echo cancellation system on the part of the point B. 

To explain this problem, attention is paid to the operation of an echo canceller 22^ connected to a first pickup 
channel which is one of echo cancellers of two channels forming the echo cancellation system at the point B. To clarify 
the operation of each receive channel, each element of the afore-mentioned combined vector which corresponds to one 
of the receive channels will hereinafter be identified in distinct form. Let x^k) and x 2 (k) represent received signal vec- 
tors in the two channels at the point B side. Letting echo path vectors of true echo paths 15^ and ^ of the receive 
channels be represented by h u (k) and h 21 (k), respectively an echo y^k) which is picked up via the echo paths 15^ 
and 1521 is given by 

y , (k) = h* (k) x , (k) + h T 2l (k) x 2 (k) (14) 

On the other hand, an echo replica y^k) which is generated in the echo canceller 22^ is given by the following equa- 
tion using estiamted echo paths h^k) and h 2 i(k) that are generated in the echo canceller 22b v 

y i (k) = h n (k)x, (k) + h J, (k)x 2 (k) (15) 



When the same speaker speaks or utters at the point A, the receievd signal vectors x^k) and x 2 (k) have a very strong 
cross-correlation. When the received signal vectors x^k) and x 2 (k) have a constant cross-correlation, the combined 
vector [h n (k), h 21 (k)] as the solution of the following equation exists infinitely, forming a subspace H x inhrent to the 
cross-correlation between the received signal vectors x^k) and x 2 (k). 

Vi(k) = y 1 (k) (16) 

On this account, in the case of using such an ordinary iterative error minimization algorithm as the NLMS algorithm, the 
combined vector [h n (k), h 21 (k)] converges to a point where the distance from the initial value to the subspace H x is 
minimum; in general, it does not converge to the trrue value [h ii (k), h 21 (k)]. 

For simplicity, consider the case where the received signal vectors x^k) and x 2 (k) are expressed by the following 
equations using constant scalar values and P2 and the original signal vector s(k). 

x t (k) = p x s(k) 9 x 2 (k) = p 2 s(k) (17) 

The subspace H x where the combined vector [h Ti (k). h L (k)] is allowed to exist can be regarded as a straight line in 
Fig. 5 which satisfies the following equation. 

p, hi i (k) + p 2 h 2i (k) = Pl h, , (k) + p 2 h 2I fk) ( 18) 

When the adaptation starts from the initial value 0, the point of convergence [h Ti (k). h 21 (k)] is obtained as follows: 
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friip(k) = p?{h„(k) + p 2 h 2l (k)/ P,}/(pf + pi)* h„(k) (19) 
h 2 .p (k) = p\ { Pl h u (k) / p 2 + h 21 (k) } / ( p] + p\ ) * h 2I (k) (20) 



Consequently, Eq. (18) is no longer satisfied upon variation in the rate between the scalar values Pt and P2, making 
10 echo cancellation impossible and hence resulting in an increase in the acoustic echo returning to the speaker at the 
other end. 

As will be understood from the above, in the application of the conventional echo cancellation system to the tele- 
communication system composed of an N-receive-channel system and an M-pickup-channel system, if received sig- 
nals of respective channels have a cross-correlation, the estimation of echo paths cannot correctly be made-this gives 
15 rise to the problem that the echo increases upon each variation in the cross-correlation between the received signals. 

SUMMARY OF THE INVENTION 

It is therefore an object of the present invention to provide a method and apparatus for multi-channel acoustic echo 
20 cancellation which permit echo cancellation even if received signals have the afore-mentioned cross-correlation in the 
conventional multi-channel acoustic echo cancellation system. 

According to the principle of the present invention, the adjustment vector for the estimated echo path is derived 
through utilization of the input-output relationships which are actually observable when received signals of respective 
channels are input into echo paths after being reproduced intact as acoustic signals by loudspeakers in the correspond- 
25 jng channels and the outputs from the echo paths are picked up by each microphone, and approximated unknown or 
imaginary input-output relationships based on inputs into the echo paths when some or all of the received signals in 
each channel are exchanged and reproduced as acoustic signals in a different channel and outputs which are picked 
up by each microphone as acoustic signals after propagation over the echo paths. 

The multi-channel acoustic echo cancellation method according to the present invention comprises the steps of: 

30 

(a) reproducing received signals of a plurality of channels as acoustic signals by a plurality of loudspeakers respec- 
tively corresponding thereto; 

(b) adding the acoustic signals from the plurality of loudspeakers by each microphone after propagating over 
respective echo paths to obtain an observable echo; 

35 (c) storing the received signals of the plurality of channels for predetermined periods of time and forming received 
signal vectors by the stored received signals for each channel; 

(d) combining the received signal vectors in all the channels into observable combined received signal vectors; 

(e) providing the combined received signal vectors to estimated echo paths having combined estimated echo path 
vectors which converge to combined vectors of the echo path vectors represented by impulse responses of the 

40 respective echo paths, whereby is generated an echo replica simulating the observable echo, the combined 
received signal vectors and the corresponding echo corresponding to the observable input-output relationships of 
the plurality of echo paths; 

(f) subtracting the echo replica from the echo to obtain a residual echo; 

(g) calculating an approximated echo replica in the case where combined exchanged received signal vectors, 
45 obtained when at least two received signals of the plurality of channels, are provided to the estimated echo paths; 

(h) approximating an echo which ought to be obtained by each microphone when the received signals exchanged 
as in step (g) propagate thereto over the plurality of echo paths; 

(i) substracting the approximated echo replica from the approximated echo to obtain an approximated residual 
echo; 

so (j) evaluating observable input-output relationships representing the relationships between the observed combined 
received signal vectors and the corresponding observable residual echo and approximated input-output relation- 
ships representing the relationships between the combined exchanged received signal vectors and the approxi- 
mated residual echo and obtaining the adjustment vector based on the evaluation; and 
(k) adjusting the estimated echo path vector by the adjustment vector. 

55 

The mufti-channel acoustic echo canceller according to the present invention comprises: 

a plurality of loudspeakers for reproducing received signals in a plurality of channels into acoustic signals and for 
outputting them; 
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a microphone connected to at least one transmission channel, acoustic paths of the acoustic signals from the plu- 
rality of loudspeakers to the microphone forming echo paths and the acoustic signals picked up by the microphone 
and combined into an echo for input into the transmission channel; 

a received signal vector generating part for temporarily storing the received signals of the plurality of channels and 
5 for generating each received signal vector; 

a vector combining part for combining the received signal vectors of the plurality of channels into combined 
received signal vectors; 

an echo replica generating part supplied with the combined received signal vectors and combined estimated echo 
path vectors simulating the combined echo path vectors obtained by combining echo path vectors representing 
10 impulse responses of the echo paths from the plurality of loudspeakers to the microphone, for outputting an observ- 
able echo replica simulating the echo; 

a subtracter for subtracting the echo replica from the echo output from the microphone and for outputting the differ- 
ence as an observable residual echo; 

a vector permuting/combining part for generating combined rearranged received signal vectors obtained by com- 
15 bining the received signals of the plurality of channels after rearranging at least two received signals of the plurality 
of channels; and 

an echo path estimating part supplied with at least the observable combined received signal vectors and the 
observable residual echoes corresponding thereto, for obtaining approximated echo replica in the case of applying 
each of the combined received signal vectors to one of the estimated echo paths, for obtaining as an approximated 

20 echo the echo to be obtained from the microphone in the case of the received signals being exchanged, for sub- 
tracting the approximated echo replica from the approximated echo to obtain an approximated residual echo, for 
evaluating an observable input-output relationship representing the relation between the combined received signal 
vector and the observable residual echo corresponding thereto and an approximated input-output relationship rep- 
resenting the rearranged combined received signal vector and the approximated residual echo corresponding 

25 thereto, for obtaining the adjustment vector on the basis of the evaluation, for generating an estimated echo vector 
obtained by adjusting the estimated each path vector with the adjustment vector, for providing it to the echo replica 
gengenerating part. 

BRIEF DESCRIPTION OF THE DRAWINGS 

30 

Fig. 1 is a block diagram showing a one-channel echo canceller; 
Fig. 2 is a block diagram showing a multi-channel acoustic echo cancellation system; ' 
Fig. 3 is a block diagram showing a conventional multi-channel echo canceller; 
Fig. 4 is a block diagram showing a stereo telecommunication system; 
35 Fig. 5 is a graph showing an echo path estimating operation which is carried out when received signals have a 
cross-correlation; 

Fig. 6 is a diagram illustrating an example of a symmetrical arrangement of microphones and loudspeakers in a 
stereo telecommunication system; 

Fig. 7 is a block diagram illustrating an example of the multi-channel acoustic echo cancellation system embodying 
40 the present invention; 

Fig. 8 is a block diagram illustrating, by way of example, the configuration of the multi-channel echo canceller 
embodying this invention method; 

Fig. 9 is a functional block diagram illustrating the configuration of an echo path estimating part in Fig. 8; 
Fig. 1 0 is a functional block diagram illustrating another configuration of the echo path estimating part in Fig. 8; 
45 Fig. 1 1 is a functional block diagram illustrating the configuration of an adjustment vector calculating part in Figs. 9 
and 10; 

Fig. 12 is a functional block diagram illustrating another configuration of the adjustment vector calculating part in 
Figs. 9 and 10; 

Fig. 13 is a graph showing convergence characteristics of an error between true and estimated echo path charac- 
so teristics; 

Fig. 14 is a graph showing the influence of a weighting coefficient assigned to an approximation error signal on the 
convergence characteristic of the error signal; 

Fig. 15 is a graph showing the influence of weighting coefficients v 1( v 2 , w 1( w 2 , orders p 1f p' 1( p' 2 and step sizes 
1*1. on the convergence characteristic of the echo path estimation; and 
55 Fig. 16 is a block diagram illustrating a teleconference system which is equipped with a sound image localization 
function in a four-point communication. 
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DESCRIPTION OF THE PREFERRED EMBODIMENTS 



PRINCIPLE 

s To facilitate a better understanding of the present invention, its principle will be described first in connection with a 
two-receive-channel system for the sake of brevity. As described previously with reference to Figs. 4 and 5, when the 
received signals x^k) and x 2 (k) are reproduced, then propagate over the corresponding echo paths h 1m (k) and h 2m (k) 
and are picked up as an echo y m (k) in the m-th pickup channel (m=2 in Fig. 4), the input-output relationship in this 
instance is given as follows: 

w 

y m 00 = »»L (k) x , (k) + h (k) x 2 (k) (21) 

is When the cross-correlation between the received signal vectors x-,(k) and x 2 (k) is constant, it is impossible to uniquely 
determine estimated echo path vectors hi m (k) and h 2m (k) which satisfy the relationship of Eq. (21), as referred to pre- 
viously. Now, assuming that an echo y' m (k) is observed in the m-th pickup channel that corresponds to received signal 
vectors x'^k) and x' 2 (k) having a cross-correlation different from that between the received signal vectors x^k) and 
x 2 (k), the following relationship is obtained as is the case with Eq. (21). 

20 

y' m (k) = h} ra (k) x' , (k) + hj m (k) x' 2 (k) (22) 



25 Letting echo replicas for the m-th pickup channel when supplied with the pairs of received signals x 1 (k) , x2(k) and x\ (k) , 
x 2 (k) be represented by y m (k) and y' m (k), they are given as follows. 

y m (k) = h L (k) x , (k) + h L (k) x 2 (k) (23) 

30 

y' m (k) = h L (k) x' t (k) 4- h L (k) x' 2 (k) (24) 



35 Further, letting error signals between the echoes y m (k), y' m (k) and the echo replicas y m (k), y' m (k) be represented by 
e m (k) and e' m (k), respectively, and echo path estimation error vectors between the echo paths h 1m (k) and h 2m (k) and 
estimated echo path vectors h 1m (k), h 2m (k) represented by Ah 1m (k) and Ah 2m (k), respectively, the error vectors are 
given by the following equations. 

y m (k)- y B (k) 

(h{ m (k) - h L (k)) x , (k) + (h t, (k) - h L (k)) x 2 (k) 

A h] m (k) x^(k) + A (k) x 2 (k) (25) 
y'm (k) - y' m (k) 

(h^ (k) - h ] m (k)) x', (k) + (h^ (k) - h L (k)) x' 2 (k) 
A h[ m (k) x' , (k) + A (k) x ' 2 (k) (26) 

That is, the following relationships are obtained. 



45 



e' m (k) = 



50 
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x[(k) x[(k) 
x'[(k) x'I(k) 









, e m (k) ' 




lAh 2ra (k) J 







(27) 
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The echo path estimation error vectors Ah 1m (k) and Ah 2m (k) cannot uniquely be derived from Eq. (27), but letting its 
minimum-norm solutions be represented by Ah 1m (k) and Ah 2m (k), respectively, the following relationship is obtained. 



'a 


him (k) 










A 


h 2m (k), 





xj (k) } 


+ 


fe m (k) I 


x'I(k)j 




ie' m (k)j 



(28) 



where (*) + indicates a generalized inverse matrix. Thus, the estimated echo vectors h 1m (k) and h 2m (k) can be adjusted 
using the minimum-norm solutions Ah 1m (k) and Ah 2m (k) as adjustment vectors as follows: 



20 



25 
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h im (k + 1) = h in, (k) + Ai m A h j m (k) 
h 2m (k + 1) = h 2m (k) + a Ah 2m (k) 



(29) 
(30) 



where p m is a step size parameter. In this case, the adjustment vectors A 1m h(k) and Ah 2m (k) are allowed to have a 
cross-correlation different from that between the received signals x^k) and x 2 (k), and hence it is possible to estimate 
the characteristic of the true echo path independently of the cross-correlation between the received signals. However, 
the above discussion presupposes that the input-output relationship for the received signals x'^k) and x' 2 (k) having a 
cross-correlation different from that between the received signals x^k) and x 2 (k), expressed by Eq. (22), could be 
observed. In practice, this input-output relationship is unknown. The present invention utilizes the condition in which this 
input-output relationship is approximately satisfied. 

It is possible to use, as the received signals x'^k) and x' 2 (k), arbitrary signals having a cross-correlation different 
from that between the received signals x^k) and x 2 (k). Now, to approximately satisfy the input-output relationship given 
by Eq. (22), consider the case where received signals of two channels are exchanged or reversed and reproduced as 
follows: 



45 



so 



55 



x , 1 (k) = x 2 (k) 
x , 2 (k) = x 1 (k) 



(31) 
(32) 



That is, when the cross-correlation between the received signals (k) and x 2 (k) is 1 2, for instance, the received signals 
x'^k) and x 2 (k) resulting from the channel exchange have a different cross-correlation 2:1. According to the present 
invention, when received signals of multiple channels are reproduced, an adjustment vector is obtained by solving the 
combination of exchanged or reversed received signals of two channels as shown by Eq. (28). A description will be 
given of several methods for obtaining the adjustment vectors Ah 1m (k) and Ah^k) on this principle. 

METHOD 1 

Method 1 uses different weights to evaluate the observable input-output relationship expressed by Eq. (21) and the 
input-output relationship of Eq. (22) which is inferred to be approximately obtained by the signal exchange based on 
Eqs. (31) and (32). For example, error signals e^k) and e' m (k) are evaluated with different weights. This weighting is 
divided into two: a fixed, time-invariant weight and a time-varying weight. 

Method (1-a) 

For example, in the case of a two-receive-channel system, the adjustment vectors are obtained by introducing 
weigthing coefficients Y m and y m to evaluate the errors e m (k) and e'm(k) in Eq. (27) with different weights and solving 
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the following equation. 





'x}(k) xj(k) ' 




f Ah lro (k)| 






5 


iX '}(k) x'J(k) 




(k)j 







(33) 
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Method (1-b) 



The error e' m (k) is separated into a component are correlated with the error e m (k) and a component decorrelated 
therewith and then weighting coefficients are introduced. For example, noting the correlation between received signals, 
is the signals x'^k) and x' 2 (k) can be separated into a portion correlated with the received signals x^k) and x 2 (k) (second 
term on the right-hand side of Eq. (34)) and the other portion (first term on the right-hand side of Eq. (34)) as expressed 
as follows: 



20 



x',(k) 
x' 2 (k) 



x',(k)\ 
x' 2 (k) r(k) 



r' (k) 



x,(k) 
x 2 (k) 



+ 



r'(k) 
r(k) 



x,(k)' 
x 2 (k). 



(34) 



25 



r'(k) = x}(k)x', (k) + xj(k)x' 2 (k) 
r(k) = x{(k)x,(k) + x 2 r (k)x 2 (k) 



(35) 
(36) 



30 Further, by multiplying the both sides of Eq. (34) by [Ah T m (k), AhL (k)] from the left-hand side and using the relation- 
ships of Eqs. (25) and (26), the error e' m (k) becomes as follows: 



•mW- 



35 



e m (k)-ge m (k)} + ^e m (k) 



(37) 



From the viewpoint of the correlation between the received signals, the error e' m (k) is separated into the component cor- 
related with the error e m (k) (second term on the right-hand side of Eq. (37)) and the other component (first term on the 
40 right-hand side of Eq. (37)). By this. Eq. (27) becomes as follows: 
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x[(k) xj(k) 
x'](k) x'J(k) 



Ah,.(k) 



50 



e_(k)-^#e m( k)U^#e m (k) 



r(k) 



r(k) 



(38) 



Then, the component of the error e' m (k) correlated with the error e m (k) and the other component are multiplied by coef- 
55 fictents v and w independently, by which Eq. (38) becomes as follows: 
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x{ (k) x](k) 

x'T(k) x'T(k) 



Ah lm (k) 



10 



+ w 7(kT e - (k) 



(39) 
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This equation is solved to obtain the adjustment vectors. 

As shown by Eq. (39), by separating the error e'm(k) into the component correlated with the error em(k) and decor- 
related component and weighting the respective components independently of each other, the resulting adjustment 
vectors match those obtainable with the afore-mentioned NLMS algorithm when setting v=0 and w=1 . Further, setting 
v=1 and w=0 has a physical meaning which corresponds to the calculation of the adjustment vectors on the basis of 
that component of the error e' m (k) obtained converning the approximated input-output relationships which is not corre- 
lated with the error e m (k) obtained concerning the observable input-output relationships. 

One possible method that is employed in the case of varying the weighting coefficients with time as mentioned 
above is to vary them in accordance with the degree of convergence of the estimated echo path vector to the true echo 
path vector as will be described later on. For example, in Method (1-a), the weighting coefficient Y m (k) is chosen to be 
equal to 1 and y m (k) smaller than 1 , whereas when the degree of simulation of the true echo path is low, the weighting 
coefficient y m (k) is chosen to be larger but not in excess of 1 . In Method (1 -b), when the degree of simulation is low, the 
coefficients v and w are set to 0 and 1 , respectively, as in the past, and as the degree of simulation increases, the values 
of the coefficients v and w are varied accordingly. 

To evaluate the degree of simulation, use is made of at least one of the ratio between the echo y m (k) and the resid- 
ual echo (i.e. error signal) e m (k), the average power ratio between the echo and the residual echo, the absolute value 
of the residual echo and the average power of the residual echo. 

METHOD 2 

Next, a description will be given of a concrete method for obtaining the vectors Ah 1m (k) and Ah 2m (k) in Eq. (28) in 
the description of the principle of the present invention or Eqs. (33) and (39) in Methods (1-a) and (1-b). 

Unknown input-output relationships approximated between inputs into echo paths when some or all of the received 
signals of respective channels are exchanged and reproduced as acoustic signals from channels different from their 
original channels and outputs to be produced when the above inputs are picked up as echo signals by microphones 
after propagation over the corresponding echo paths. This approximation is made through utilization of known input- 
40 output relationships actually observed when the received signals x m (k) of respective channels are reproduced intact as 
acoustic signals and picked up by microphones after propagating over the corresponding echo paths, the residual echo 
(an error signal) for the evaluation of the input-output relationships and the similarity of the echo paths. This can be 
done by such concrete methods as described below. 

45 Method (2-a) 

This method utilizes the similarity of echo paths on the assumption that equivalent echo paths are formed between 
loudspeakers and microphones of physical arrangements similar in terms of the distance therebetween and their orien- 
tation. For example, when the receive and the pickup system are both two-channel, the input-output relationships for 
so the respective pickup channels are as follows: 



. 30 



35' 
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y , (k) = h|, (k) x , (k) + hj, (k) x 2 (k) 
y 2 (k) = h| 2 (k) x , (k) + h T n (k) x 2 (k) 



(40) 
(41) 



Now, supposing that when loudspeakers 12,, 12 2 and microphones 16, and 16, are arranged bilaterally symmet- 
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rical, including their directional patterns, as shown in Fig. 6, the following equations hold 

h n (k) = h 22 (k) 
H2i(k) = h 12 (k) 



(42) 
(43) 
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From these equations and Eqs. (40) and (41), the following relationships can be derived. 
y'i (k) = h[, (k) x 2 (k) 4- hj x (k) x , (k) = y 2 (k) 
y' 2 (k) - h} 2 (k)x 2 (k) + (k)x, (k) = yi (k) 



(44) 
(45) 



These relationships are indeed the input-output relationships which are obtained when the receive channels are 
exchanged; hence, e'^segfk) and e'^k^e^k) hold. By applying these approximated results to Eqs. (28), (33) and 
20 (39) as well as (44) and (45), three methods could be obtained as described below. 

Method (2-a-1) 

By applying the channel exchange and the echo path approximation to Eq. (28), the following simultaneous equa- 
ls tions are obtained, and by solving Eq. (46), the adjustment vectors can be obtained. 
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A h„(k) 




' *T(k) 


x[(k) 0 


0 


+ 




(k) 


A h 2I (k) 




xl(k) 


x[(k) 0 


0 






(k) 


A h 12 (k) 




0 


0 x|(k) 


xj(k) 






(k) 


.A £ 22 (k). 




0 


0 xj(k) 


x j(k) 




. e > 


(k) 



(46) 
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Method (2-a-2) 

By applying the channel exchange and the echo path approximation to Eq. (33), the following simultaneous equa- 
tions are obtained, and by solving Eq. (47), the adjustment vectors can be obtained. 



x[(k) xj(k) 0 0 

xj(k) x[(k) 0 0 

0 0 x]*(k) x[(k) 

0 0 xj(k) x}(k) 



A h n(k) 




7iei(k) 


A h 2I (k) 




Y'ie 2 (k) 


A £ 12 (k) 




Y2e 2 (k) 


.A h 22 (k) 




.7' 2 e,(k) 



(47) 
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Method (2-a-3) 

Setting c(k)=y'(k)Y \k) and applying the channel exchange and the echo path approximation to Eq. (39), the fol- 
lowing simultaneous equations are obtained, and by solving Eq. (48), the adjustment vectors are obtained. 
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x{(k) x*(k) 0 0 

xj(k) x|(k) 0 0 

0 0 x](k) x£(k) 

0 0 xj(k) x|(k) 



A h,i(k) 
A h 2 i(k) 
A hi 2 (k) 
A h 22 (k) 



20 



2S 



v, {e 2 (k)-c(k) ei (k)} + w^e^k) 
e 2 (k) 

v 2 { e jto-cWe^k) } + w 2 c(k)e 2 (k) 



(48) 



30 Method 2-b) 

Another method (2-b) is one that can be used even if the afore-mentioned assumption in Method (2-a) ( for example, 
the assumption that the echo paths between loudspeaker and microphones of similar physical arrangements are the 
same, as in the case of Eqs. (42) and (43), does not hold with high accuracy. When the receive and the pickup system 
35 are both two-channel as is the case with the above, the following equations are used in place of Eqs. (42) and (43). 



40 



hii(k) = h 2 2<k) + fi(k) 
h 2 i(k) - h 12 (k) + f 2 (k) 



(49) 
(50) 



where f^k) and f 2 (k) represent a similarity error between the true echo path vectors h^k) and h 22 (k) and a similarity 
error between the true echo path vectors h 12 (k) and h 21 (k), respectively. On the other hand, a similarity error f ^k) 
45 between the estimated echo path vectors h^fk) and h^fk) and a similarity error f 2 (k) between the estimated echo 
path vectors h 12 (k) and h 21 (k) are expressed as follows: 



fin(k) - fi 22 (k) + f,(k) 

fi 2! (k) = fi 12 (k) + f 2 (k; 



(51) 
(52) 



Further, the differences between the similarity errors of the true and estimated echo paths are defined by the following 
55 equations: 
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Af,(k) -f,(k) - f,(k) (53) 
Af,(k) -f 2 (k) -f 2 (k) (54) 

These differences will hereinafter be referred to as similarity error differences. Then, letting y',(k) and y' 2 (k) be outputs 
which are obtained in the first and second pickup channels when reproducing the received signals x 1 (k) and x 2 (k) after 
exchanging the receive channels, the following equations are obtained using the relationships of Eqs. (49), (50) and 
,o Eqs. (40), (41). 

y' l (k) = h} l (k)x 2 (k) + hl,(k)x 1 (k) 

„ = y 2 (k) + tj (k) x 2 (k) + f J (k) x , (k) (55) 

y'z (k) = h] 2 (k) x 2 (k) + hj 2 (k) x , (k) 

= y , (k) - f 7 (k) x , (k) - f T (k) x 2 (k) (56) 

20 

The outputs y'^k) and y' 2 (k) are simulated to be y'^k) and y' 2 (k) by the following equations, using the estimated echo 
path vectors h u (k), h 21 (k), h 12 (k), h^k) and Eqs. (51), (52). 

y', (k) = hL (k)x 2 (k) + hL (k)x, (k) 

= y 2 (k) + U (k) x 2 (k) + f I (k) x. (k) (57) 



30 



35 



y'z (k) = h ] 2 (k)x 2 (k) + h L (k) x, (k) 

= y i (k) — f7 (k) x, (k) - f I (k) x 2 (k) (58) 



Errors e'-ifk) and e' 2 (k) between the outputs y'i(k), y 2 (k) and their simulated values y 1 (k), y' 2 (k) are given as follows: 

e'j (k) = A h n (k) x 2 (k) + A h L (k) x { (k) 

= e 2 (k) + A f ] (k) x 2 (k) + A fl(k)x, (k) (59) 



45 



50 



e' 2 (k) = A h ] 2 (k) x 2 (k) + A h L (k) x, (k) 

= e, (k) — A f I (k) Xj (k) - A f I (k) x 2 (k) (60) 



where: 

55 e 1 (k) = y 1 M-y 1 (k) (61) 

e 2 (k) = y 2 (k)-y 2 (k) (62 ) 
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Af,(k) = f, (k)- f,(k) 

A f 2 (k) = f, (k) - f 2 (k) 



(63) 
(64) 



Since the similarity error differences A, f (k) and Af 2 (k) are expressed in Eqs. (63) and (64) as unknown similarity error 
w vectors f ,(k) and f 2 (k), respectively, the errors e'1 (k) and e'2(k) cannot correctly be known. Then, solving Eqs. (59) and 
(60) for the known errors ^(k) and e,(k), we have 



15 



e 2 (k) = A hi, (k) x 2 (k) + A £1, (k) x , (k) 
- A f I (k) x 2 (k) - A f I (k) x , (k) 



(65) 



20 e, (k) = A friz (k) x 2 (k) + A h 22 (k) x , (k) 

+ A fl(k)x, (k) + A fl(k)x 2 (k) 



25 On the other hand, the following equations are obained from Eq. (25). 



e, (k) = A h Ii (k) x , (k) + A ftL (k) x 2 (k) 
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e 2 (k) = A £I 2 (k) x , (k) + A h L (k) x 2 (k) 
Therefore, the following simultaneous equations are obtained from Eqs. (65) through (68). 



xj(k) xj(k) 0 0 0 0 

xj(k) x|(k) 0 0 -xj(k) -x[(k) 

0 0 x}(k) xj(k) 0 0 

0 0 xj(k) x|(k) x]"(k) xj(k) 



(66) 



(67) 
(68) 



A £ n (k) 






A &21 (k) 




' e, (k) ' 


A h, 2 (k) 




e 2 (k) 


A h 22 (k) 




e 2 (k) 


A t , (k) 






A f 2 (k) 







(69) 

55 The adjustment vectors of the estimated echo paths are obtained as minimum-norm solutions of the simultaneous 
equations of Eq. (69). In this case, the similarity error differences Af ^k) and Af 2 (k) need not calculated in practice. 
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Method (2-b-1) 

In the calculation of the estimated echo path adjustment vectors based on Eq. (69), the introduction of the weight- 
ing coefficients in Eq. (33) gives 



x|(k) xj(k) 0 0 0 0 

xj(k) x](k) 0 0 -y'i xl(k) -Y'ix[(k) 

0 0 x[(k) x[(k) 0 0 

0 0 xj(k) x[(k) y' 2 x](k) y' 2 xj(k) 















A li 2i (k) 




Yi e,(k) ' 


A £12 (k) 




Y'i e 2 (k) 






Y2 e 2 (k) 


A h 22 (k) 




A t (k) 




.Y' 2 e, (k). 


A ? 2 (k) 







(70) 



25 



30 



In this instance, the weighting coefficients are applied following Eqs. (59) and (60) as follows: 

Y'i e',(k) = y'i e 2 (k) + Y 'i A f ^(k)x 2 (k)+ y'i A f I(k)x,(k) (71) 
T'2 e' 2 (k) = Y'2 ci(k) - Y'2 A f I(k)x,(k)- y'i A f I(k)x 2 (k) (72) 



35 

Method (2-D-2) 

This method introduces time-invariant or time-varying weighting coefficients which permit control of the influence 
40 of the echo path similarity error vectors. For example, when the receive and pickup systems are both two-channel,the 
evaluation of the afore-mentioned similarity error differences At ^k) and Af 2 (k) is weighted with respect to the evalua- 
tion of the estimated echo path vectors Ah^fk), Ah 21 (k), Ah 12 (k), Afi^fk). For example, introducing into Eq. (63) 
weighting coefficients fr, , k 2 , fr 3 and as elements by which the similarity error differences Af 1 (k) and Af 2 (k), we have 
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x](k) xj(k) 0 0 0 0 

xj(k) x[(k) 0 0 -K l y , l x](k) — ic 2 y'l x|(k) 

0 0 x[(k) xj(k) 0 0 

0 0 xj(k) x }(k) ^Y' 2 x}(k) JC 4 Y' 2 xI(k) 



A h n (k) 



A h 2i (k) 



A h 12 (k) 
A h 22 (k) 



A f i (k) 



A f 2 (k) 
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Yi e, (k) 
Y'i e 2 (k) 
Y2 e 2 (k) 
Y'z e, (k) 



(73) 



so In this instance, if Ih, j 04- 622(^1^ jfk)!! is small, then it is inferred from Eqs. (46) and (47) that the similarity error vec- 
tor ^(k) is small; hence, if the above ratio is smaller than a predetermined threshold value K1, for instance, control is 
effected to make the weighting coefficient ft, smaller than 1, for example. Similarly, when Dfi 2 i(k)-h 12 (k)o/lh 21 (k)[| is 
smaller than a predetermined threshold value K2, control is effected to make the weighting coefficient ft 2 smaller than 
1 , for instance. 
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Method (2-b-3) 



based 



According to this method, introducing weighting coefficients v1, v 2 , and w 2 based on Method (1-b) into Eq. (69) 
3d on Method (2-b) and setting c(k)=r'(k)r" 1 (k) , we have 
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xj(k) xj(k) 0 0 0 0 

xj(k) x|(k) 0 0 -v, xj(k) -v, x}(k) 

0 0 x}(k) xj(k) 0 0 

0 0 xj(k) x|(k) v 2 x|(k) v 2 xj(k) 



A fi'n (k) 



A £21 (k) 



A £ I2 (k) 



A h22(k) 



A f 1 (k) 



A f 2 (k) 



20 



25 



v x { e 2 (k) - c (k) c,(k) } + w , c (k) c,(k) 
e 2 (k) 

v 2 { Cl (k) - c (k) e 2 (k) } + w 2 c (k) e 2 (k) 



(74) 



By setting the following equations (75) and (76) and solving simultaneous equations (73), the adjustment vectors can 
be obtained. 
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r' <k) = x{(k)x 2 (k) + x£ (k) Xl (k) 
r(k) = x[(k) Xl (k) + xJ(k) x 2 (k) 



(75) 
(76) 



40 METHOD 3 

A third method derives the adjustment vectors of the estimated echo path vectors by evaluating, in combination, the 
input-output relationships obtained by approximating those observed previously and the input-output relationship 
obtained by approximating those observed at the current time. 

45 

Method (3-a) 



In concrete terms, a projection algorithm is applied to methods (2-a) and (2-b) which utilize the afore-mentioned 
channel exchange. The projection algorithm is to adjust the estimated echo path vectors so that the input-output rela- 
50 tionships in an n-th received signal channel at the current and previous time p n are satisfied simultaneously, where p n 
is an integer that does not exceed the number of taps L of each estimated echo path vector. In the first place, the n-th 
channel received signal vectors from the current time back to the previous time p n are generically expressed as follows: 

a X n <P>(k) = [x n (k) f xii(k-l), ... f x n (k-p+l)] (77) 

Again, when the receive and pickup systems are both two-channel, setting error signals as follows: 
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= [e,(k),(l- 


-^,)e,(k- 


1),. 


..,(1- 




e,(k- 


-P. + 1)] T 


(78) 


eS p,,) (k) 


= [e 2 (k),(l 


-M2)e 2 (k- 


■1).. 


..,(1 




' e 2 (k- 


-p'i + 1) ] T 


(79) 


ei P2> (k) 


= [e 2 (k),(l- 


-/* 2 )e 2 (k- 


1), • 


...d- 




e 2 (k- 


P 2 +D ] T 


(80) 


ei P ' 2, (k) 


= [e,(k), (1 


-/u 1 )e,(k- 


1),. 


-,(1 




' e,(k- 


-P'2 + D ] T 


(81) 
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and applying the projection algorithm to Eq. (73), we have 

0 0 
0 

1 * * 

(D.)T (t 

0 0 
0 0 



x ( , p ' )T (k) x! p > )T ( k) 



xl PVT (k) x (p '' ,T (k) 0 



0 0 

^Y'.xf'^k) -^y'.X^V) 
0 0 

X 2 P '' )T (k) Xf^k) >3Y' 2 X ( ^ )T (k) ^Y' 2 X; PVT (k) 



x ( , P2)T (k) X^^k) 



X 
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A h ii (k) 








A h 21 (k) 




y i 


e ( , Pl) (k) ' 


A hi 2 (k) 






ef'^k) 


A h 22 (k) 




yi 


e 2 2 (k) 


A f i (k) 






e, 2 (k) 


Af 2 (k) 









(82) 



Let it be assumed that parameters for determining how far back to the previous time for using the input-output relation- 
so ships can be set independently within the ranges in which they do not individually exceed the numbers of taps L of the 
estimated echo path vectors just like p-i , p'i , P2 and p' 2 which satisfy a condition min{p 1 .p^^maxlp'! ,p' 2 }. 

Method (3-b) 

55 Applying the projection algorithm using Eqs. (77) through (81) to Eq. (73) based on Method (2-b-3) and setting a 
matrix for the cross-correlation as follows: 

c iW- r Wp,>W r \,*p,>« 
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C 2 (k) = R V 2 xp 2 )( k ) R (p 2 xp 2 )( k ) 



(83) 



we have 
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X ( , Pl)T (k) X?' )T (k) 



X 



.(P',> T 

>2 

0 
0 



A h ii (k) 



A h 2i (k) 



A hi 2 (k) 



A h 22 (k) 



A ?i (k) 



A f 2 (k) 



(k) xf l)T (k) 



0 0 0 

0 0 -v 1 Xj P ' |,T (k) 



X ( , P2)T (k) X 2 P2 ' T (k) 



0 X 2 P ' 2)T (k) X ( , P ' 2,T (k) v 2 X <p ' 2)T (k) 



0 

-v, X (P ' ,)T (k) 



0 



v 2 X 2 P ' 2)T (k) 



e <P "(k) 



v, { e^^W-CCk) e (p,) (k)} + w, C,(k)e (p,) (k) 

(Pi > ,. V 

e (k) 

v, { e (p ' 2> (k)-C 2 (k) e' p 2 2) (k)} + w 2 C 2 (k) e (p 2 2> (k) 



(84) 

The adjustment vectors are obtained as the minimum-norm solution of the above simultaneous equation (84). The n-th 
channel received signal vectors back to the previous time p are generically expressed as follows: 



Xn (P, (k) = [Xn(k),*n(k-l),...,Xr,(k-p+l)] 



(85) 



The parameters for determining how far back to the previous time for using the input-output relationships are set as , 
p* 1t P2 and p' 2 , which satisfy the condition min{p 1 ,p 2 }^max{p , 1 ,py and are given as follows: 



R' (p( , xp.) (*) = X <P ' ,)T (k)X 2 Pl) (k) + X 2 Pl)T (k)Xi Pl) (k) 
R'<p' 2 x P2 , 00 = X (p ' 2)T (k)X ( 2 P2, (k) + X 2 p ' 2)T (k)X (P2) (k) 
R (pi xpi) (k) = X (P ' )T (k)Xi Pl) (k) + X 2 Pl)T (k)X 2 Pl) (k) 
R (p2 Xpz) (k) = X ( , P2)T (k)X (P2) (k) + X 2 P2)T (k)X 2 P2> (k) 



(86) 
(87) 
(88) 
(89) 
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ei tPl) (k) = [e 1 (k),(1- l i 1 )e 1 (k-1) (l^/^e^+l)] 7 

e 2 (P ' l) (k) = [e 2 (k),(1^ 2 )e 2 (k-1) (1-fi 2 ) Pr1 e 2 (k-p' 1+ 1)] T 

e 2 (Pl) (k) = [e 2 (k) l (l. t i 2 )e 2 (k.l),...,(l-ji 2 ) P2 * 1 e 2 (k.p 2+ 1)] T 
e ! * 2> (k) = [e , (k).(1 ~\x 1 )e 1 (k-1) (1 -n 1 ) p ' 2-1 e , (k-p' 2+ 1 )] T 



(90) 

(91) 
(92) 
(93) 



Method (3-b-1) 



is As is the case with Eq. 84), the adjustment vectors can also be obtained by introducing the time-invariant or time- 
varying weighting coefficients k h k 2% k 3 and k*, which permit control the influence of the echo path similarity error vec- 
tors in Method (2-b-2), into Eq. (84) of Method (3-b) as follows: 
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X ( , P,)T (k) X?' )T (k) 0 

x; p ' i)T (k> x ( , p, ' )T (k) o 

0 0 

0 0 



0 
0 



X ( ^ )T (k) X^ ,T (k) 



^v ( Xf' )T (k) -k^x;-'"^) 



<p'l> T / 



0 0 

x; p *"(k) x;^"(k) fc 3 v 2 x ( l p VT (k) k 4 v 2 x< p ' 2)T oo 



A hu(k) 
A h 2 i(k) 
A h ii(k) 
A h22(k) 
A f.(k) 
A f 2 (k) 



v, { e <P 2 1> (k)-C.(k) e (Pl) (k) }+ w ,C,(k) e*'* (k) 



5 <P /(k) 



v 2 { e (p ' z> (k)-C,(k) e (p 2 2> (k) }+w 2 C a (k) e (p 2 J> (k) 
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Method (3-b-2) 

It is also possible to obtain the adjustment vectors by introducing weighting coefficients ^ and ^ into Eq. (93) as 
follows: 
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10 



x ( , Pl)T (k) x 2 p ' )T (k) 0 

X 2 P ' ,)T (k) xf'^k) 0 



0 
0 



0 

6 



0 
0 



X ( , P2)T (k) xt Pl)T (k) 



•K.v.X^'^k) -^ Vl X (p ' l)T (k) 



X 2 P '* )T (k) X ( ^ )T (k) K s v t X«*! T <n K 4 y 2 Xf^(k) 
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SO 
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30 



X 



A hn(k) 

A h 21 (k) 

A h 12 (k) 

A h 22 (k) 

A f .(k) 

LA f 2 (k) 



e (Pl ' (k) 



V, {e ( ;'» ) (k)-C I (k)e ,p .' ) (k)} + Wl C,(k)e (Pl) (k) 



e <P ='(k) 



X 2 v 2 { e (p ' 2) (k)-C 2 (k) e' p 2 2) (k) } + w 2 C 2 (k) e <P 2 z> (k) 



(95) 



35 and by controlling the weighting in accordance with the balance between the weighting coefficients k 2% k 3 , k$ and 
METHOD 4 

40 In the various methods described above, an ES (exponentially weighted step-size) algorithm can be further applied 
with which it is possible to provide different adjustment weighting coefficients for each tap on the basis of the exponen- 
tial decay property of impulse responses of the echo path. 
For example, setting Eq. (33) in Method (1-a) as follows: 



45 



M(k) = 



xT(k) xj(k) 
x'I(k) x'I(k) 



(96) 



50 



Eq. (33) becomes as follows: 



55 



M(k) 



A h i m (k) 








. A h2m(k) . 




Y' 

m 


e ' m ( k >. 



(97) 



The minimum-norm solution of this simultaneous equations is given by 
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A h Ini (k) 
A h 2m(k) 



= M T (k) [M(k)M T (k) +5l] 



y m e (k) 

y' m e ' ( fc ) 



(98) 



10 



15 



20 



where I is a unit matrix and 6 is a small constant for stabilizing the inverse matrix operation. To apply the ES algorithm 
to the above equation (98), a basic exponential decay matrix A< r > is prepared which is expressed by 



A (r > = 



~ (r) 



a 2 



0 



„ (r) 
« L 



(99) 



where: 



25 



a W ,-« W (X») M ,i-1 L 



(100) 



0<X (r) *1 



30 Alternatively, L sequences of numbers given by Eq. (100) are divided into equally or unequally spaced blocks and the 
value of each aW, in each block is made equal to the value of the first af?\ in the same block, by which the basic expo- 
nential decay matrix A< r > is obtained in a simplified form which has an advantage in terms of computational complexity. 
The matrix is set as follows: 



35 



A = 



A (,) 0 
0 A (2) 



(101) 



This is applied to Eq. (97) as follows: 



45 



A h . m (k) 
A h 2»(k) 



= AM T (k)[M(k)AM T (k) +6l] -1 



' m up ' 

y' m e ' ( k ) 



(102) 



From the minimum-norm solution thus obtained, the adjustment vectors of the respective estimated echo path vectors 
so are derived. 

Similarly, if the following equation is set for Eq. (82) in Method (3-a) employing the afore-mentioned projection algo- 
rithm 
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M(k) 



10 



15 



x ( , p ' )T (k) x; p ' )T ( k) 



0 



0 



0 



0 



0 -^y'.X^V) -K 2 y\X { ^ )T (k) 



xf' )T (k) X ( , P '' )T (k) 0 
0 0 X ( , P2)T (k) X 2 r2 '"(k) 0 0 

o o x^ )T ( k) x; p '> )T ( k) ^ Y ' 2 x; p ' 2)T (k) K, y ' 2 x^\k) 



20 Eq. (82) becomes as follows: 



(103) 
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M(k) 



A hi, (k) 
A h 2i (k) 



A ha (k) 



A h 22 (k) 



A f i(k) 
A f 2 (k) 



Y.e;""(k) 
Y'»e 2 p,l) (k) 
Y2e ( 2 P2, (k) 
Y2e (P ' 2) (k) 



(104) 



The minimum-norm solution of this simultaneous equations is given by 
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A h u (k) 



A h 2i (k) 



A h i2 (k) 



A h 22 (k) 



A f . (k) 



A f 2 (k) 



= M T (k) [M (k) M T (k) + <5 1] 1 



r. e (Pl) (k) 
y',e 2 Pl) (k) 



y2e 2 " 2 '(k) 



Vl> (k) 



(105) 



To apply the ES algorithm to this, the following matrix is generated which is composed of the basic exponential decay 
matrix A^. 
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A = 



10 



(2) 



(3) 



(4) 



(6) 



(106) 



This is applied to Eq. (104) as follows: 



A h u (k) 






A £21 (k) 




Y.e; p,) (k) " 


A £12 (k) 
A £22 (k) 


= AM T (k) [M (k) AM T (k) + <5 1] 1 


Y'.e^Ck) 
Y2 e 2 Pj> (k) 


A ft (k) 






A f 2 (k) 







30 

The minimum-norm solution thus obtained is used to obtain the adjustment vectors of the estimated echo path vectors. 
It is apparent that the ES algorithm can similarly be applied to the other methods, and no description will be given of 
them. 

35 * As described above, according to the multi-channel acoustic echo cancellation method of the present invention, 
unknown input-output relationships between imaginary inputs in the case where some or all of the multi-channel 
received signals are exchanged and then reproduced as acoustic signals from channels different from their original 
channels and imaginary outputs which ought to be obtained when the imaginary inputs are observed as echoes by 
microphones after propagating over the corresponding echo paths are obtained approximately. The approximated 

40 input-output relationships and input-output relationships, which are observed when received signals of respective chan- 
nels are reproduced intact as acoustic signals and are picked up by microphones after propagation over the corre- 
sponding echo paths as in the prior art, are both evaluated to obtain the adjustment vectors of the estimated echo 
paths-this speeds up the estimation of the true echo path in the echo path estimating part. 

45 Echo Canceller 

Next, examples of the echo cancellers embodying the above-described methods of the present invention will be 
described in comparison with conventional device configurations. The conventional echo cancellation system having an 
N-receive-channel system and an M-pickup- channel system is formed by providing N-channel echo cancellers 22 1f 

50 2*2 22m independently of M pickup channels as shown in Fig. 2. In contrast thereto, according to the present inven- 
tion, the echo cancellation system with the N-receive-channel system and the M-pickup-channel system is formed as 
an NxM channel echo canceller 23 as depicted in Fig. 7, which is adapted to exchange information between channels 
and make the echo path estimation as shown in detail in Fig. 8. 

The configuration of the echo canceller shown in Fig. 8 is the basic configuration that is applicable to any of Meth- 

55 ods 1 to 4 of the present invention, and as will be described below, this configuration features a vector permuting/com- 
bining part 41 in comparison with the echo path estimating part 19 m in the prior art example of Fig. 3. In the vector 
computing/combining part 41. the received signal vectors x^k), x 2 (k), ... are arranged in D ways by rearranging them 
through their exchange with received signal vectors of other channels, and these vectors are combined into D vectors 
x< 1 >(k), x< 2 )(k), ... x<°>(k). By approximating the input-output relationships for the combined vectors x< 1 >(k), x< 2 >(k) f ... 
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x( D >(k) through use of the similarity of echo paths, estimated echo path adjustment vectors Ah^k), • • • , Ah M (k) can 
be obtained. 

The NxM channel echo canceller has N received signal storage/vector generating parts 17 1 to 17 N corresponding 
to N channels as shown in Fig. 8, which hold L received signals up to the current time (k) determined for the respective 

5 received signal channels and generate the received signal vectors x^k) to x N (k) expressed by Eqs. (7) to (9) as is the 
case with the received signal storage/vector generating parts 17 1 to 17 N in Fig. 3. The received signal vectors x^k) to 
x N (k) thus obtained are combined by a vector combining part 24 into the combined vectors x(k) expressed by Eq. (10), 
which are provided to echo replica generating parts 18 n to 18 M . The echo replica generating part 18 m (where m=1 ...,M) 
for each m-th pickup channel calculates an echo replica by Eq. (13) from the combined vector x(k) and the combined 

io estimated echo path vector h m (k) and provides the echo replica y m (k) to a subtracter 21 m . Each subtracter 21 m outputs 
the difference between the echo y m (k) and the echo replica y m (k) as the residual echo (i.e. an error signal) e m (k). 

As mentioned previously, what is characteristic of the echo canceller according to the present invention is the vector 
computing/combining part 41, which rearranges the N-channel received signal vectors x^k) to x N (k) in D ways by 
exchanging the received signal vectors of the respective channels, then combines the received signals of the D orders 

is of arrangement into D combined vectors x^fk), x^(k), ... x( D) (k) by Eq. (10) as is the case with the vector combining 
part 24 and provides the D combined vectors to the echo path estimating part 19. The echo path estimating part 19 is 
supplied with the D combined vectors x< 1 >(k) to x (D )(k), the combined vector x(k) from the vector combining part 24, the 
error signals e^k) to e M (k) from the subtracters 21 1 to 21 M and, if necessary, the echoes y^k) to y M (k) as indicated by 
the broken lines. The echo path estimating part 19 calculates the estimated echo path adjustment vectors A h^k), • • •, 

20 Ah M (k) by any one of the afore-mentioned methods and further calculates the estimated echo path vectors h-, (k+1 ) to 
h M (k+1) at the next time (k+1) by Eqs. (29) and (30), for instance. 

Fig. 9 is a functional block diagram of the echo path estimating part 19 for use in the execution of the afore-men- 
tioned methods (1-a), (2-a-1), (2-a-2), (2-b-10, (2-b-2) and (3-a) which involve assigning the coefficients y m ancl Vm to 
the error signals e m (k) and e* m (k). The combined vectors x* 1 >(k) to x< D) (k) from the vector permuting/combining part 24 

25 and the combined vectors x(k) are provided to an adjustment vector calculating part 19A and a weighting coefficient 
assigning part 19B as well. 

A weighting coefficient control part 19E introduces, by Method (1-a), the weighting coefficients y m and y m into the 
measured and approximated input-output relationships, respectively, then changes the weighting coefficients in accord- 
ance with the degree of convergence of the estimated echo path vector to the true echo path and provides the weighting 

30 coefficients to weighting coefficient assigning parts 19B, 19C and 19D. That is, the weighting coefficient control part 
1 9E in this example, takes thereinto the ech o es y^k) to y M (k) together with the error signals e-\ (k) to e M (k), then calcu- 
lates their average power ratio r pm =|y m (k)| 2 /|e m (k)| 2 as an index representing the degree of convergence of the esti- 
mated echo path vector and, based on the value of the index, determines the weighting coefficients y m and Ym- 
weighting coefficient y m in Eq. (33), (70), (73), or (82) is always set at 1, for instance, and when the power ratio r pm 

35 becomes larger than a predetermined positive value r th , the weighting coefficient y'm *s set at a predetermined large 
positive value which does not exceed 1, and when the power ratio r pm is equal to or smaller than the predetermined 
positive value r th , the weighting coefficient y m is set at a predetermined small positive value which does not exceed 1 
either. A weighting coefficient evaluation and control part 19G is used in the case of Method (2-b-2); it determines, 
based on the adjustment vector Af(k), the weighting coefficients * 1( k 2 , k z and k A for controlling the influence of the 

40 echo path similarity error vector At and provides the weighting coefficients to the weighting coefficient assigning part 
19B. The weighting coefficient assigning part 19B assigns the received signal vectors x j and x \ with weights by com- 
binations of the weighting coefficients fc, to k^ and y 1( Y 2 as shown in Eq. (66) and provides them to the adjustment 
vector calculating part 19A. The weighting coefficients assigning parts 19C and 19D assign the weighting coefficients 
y'i . Y*2 and Yi . Y2 to the error signals e^k) and e2(k) and provide them to the adjustment vector calculating part 19A.The 

45 adjustment vector calculating part 19A uses the signals applied thereto to solve any one of Eqs. (33), (70), (73) and 
(84), thereby obtaining the adjustment vector Ah mn (k), which is provided to an adaptive filter updating part 19F. The 
adaptive filter updating part 19F adjusts the estimated echo path vector by Eqs. (29) and (30), then outputs it as the 
estimated echo path vector at time (k+1) and provides it to each of the echo replica generating parts 1 8 1 to 18 M . 
Fig. 10 is a functional block diagram of a multi-channel acoustic echo canceller which embodies the afore-men- 

50 tioned Methods (1-b). (2-a-3), (2-b-3), (3-b-1) and (3-b-2) which separate the error signal e'^k) into components and 
weight them with the coefficients v and w. In this example, as in the Fig. 9 example, the weighting coefficient evalua- 
tion/control part 19G uses the adjustment vector Ah(k) to determine the weighting coefficients k^Xok^ which controls 
the influence of the echo path similarity error difference Af(k) and provides them to the weighting coefficient assigning 
part 19B. The adjustment vector calculating part 19A is supplied with the combined received signal vector X(k) and 

55 channel -exchanged combined received signal vectors X (10 )(k), X fD) (k). In this embodiment, the error signal e' m (k) is 
divided into a component correlated with the error signal e m (k) and the other component and they are assigned with the 
weighting coefficients w and v, respectively as shown in Eq. (39), (74), (84), (94), or (95). To this end, as is the case with 
the above, the weighting coefficient control part 19E calculates from the echoes y^k) to y M (k) and the error signals 
e!(k) to e M (k) their average power ratio r pm =|y m (k)| 2 /|e m (k)| 2 as an index indicating the degree of convergence of the 
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estimated echo path vector, and determines the values of the coefficients w and v accordingly. Furthermore, a cross- 
correlation^ calculating part 19H calculates the cross-correlation between the received signals by a matrix 
c(k)=r'(k)r (k) or C-i(k) and Cyk) in Eqs. (86) to (89) and provides it to a component separating part 19J. 

The component separating part 19J separates the error signal e' m (k) into the component correlated with the error 
signal e m (k) and the uncorreiated component, which are fed to weighting coefficient assigning parts 19K and 19L and 
assigned with the weighting coefficients w and v, respectively. The correlated component and the other component 
assigned with the weighting coefficients are added by an adder 19M and the added output is applied to the adjustment 
vector calculating part 19A. The adjustment vector calculating part 19A uses the signals applied thereto to solve the 
simultaneous equations (37), (74), (84), (94), or (95) to calculate the adjustment vector Ah(k), which is provided to the 
adaptive filter updating part 19F and the weighting coefficient evaluation/control part 19G as well. Based on the adjust- 
ment vector provided thereto, the adaptive filter updating part 19F calculates the estimated echo path vector by Eqs. 
(27) and (30) and outputs it. 

Fig. 1 1 illustrates the functional block configuration of the adjustment vector calculating part 19A in the echo path 
estimging part 19 of Figs. 9 and 10 which permits the application of a p-th order projection algorithm of Method 3 and 
the ES algorithm of Method 4 when the echo paths are highly symmetrical and hence Method (2-a) is used. To execute 
the p-th order projection algorithm, the received signal vectors are provided to a signal storage part 19A2, wherein (p- 
1) preceding received signal vectors are held, and the received signal matrix X(P> n of Eq. (85), which is a set of the 
stored received signal vectors and the received signal vectors at the current time k, is fed to an exponential weighting 
coefficient assigning part 19A1 , wherein the received signal matrix is assigned with a weighting coefficient by the basic 
exponential decay matrix A< r >, thereafter being provided to a simultaneous equation calculating part 19A3. At the same 
time, the received signal vector weighted in the weighting coefficient assigning part 19B in Figs. 9 and 10 is also pro- 
vided to the simultaneous equation calculating part 19A3. 

On the other hand, the weighted measured error signals e^k), .... e M (k) and the weighted approximated error sig- 
nals e'i( k ) s'mM are also stored as sets of error signals at (p n -1 ) previous points in time and they are applied to the 

simultaneous equations calculating part 19A3 together with error signals at the current time. The simultaneous equa- 
tions calculating part 19A3 solves the simultaneous equations (47) from the signals fed thereto to calculate the adjust- 
ment vector Ah(k). In the case of Fig. 10, the set of measured error signals e^k), .... e M (k) at (p n -1) previous times are 
stored in the signal storage part 19A4 and are provided therefrom to the simultaneous equations calculating part 19A3 
together with the set of measured error signals at the current time and the set of component-separated, weighted 
approximated error signals from the adder 19M is provided to the signal storage part 19A5, wherein a set of weighted 
approximated error signals at (p n -1) previous times is held. The (p n -1) sets of weighted approximated error signals and 
the set of error signals at the current time are fed to the simultaneous equations calculating part 19A3. The simultane- 
ous equations calculating part 19A3 uses these signals to solve, for example, Eq. (74) to obtain the adjustment vector. 

Fig. 12 illustrates the functional block configuration of the adjustment vector calculating part 19A which is used in 
the echo path estimating part 19 of Figs. 9 and 10 in the case of calculating the adjustment vector by Method (2-b), tak- 
ing into account low symmetry of the echo path (i.e. The similarity error). Also in this case, the adjustment vector calcu- 
lating part 19A is adapted to execute the p-th order projection algorithm of Method 3 and the ES algorithm of Method 
4. This embodiment differs from the Fig. 1 1 embodiment in that the simultaneous equations calculating part 19A3 cal- 
culates the adjustment vector by solving any one of the simultaneous equations (69), (70), (73), (82), (84), (94) and (95) 
containing the similarity error difference Af and that a signal storage part 1 9A6 and an exponential weighting coefficient 
assigning part 19A7 are provided also for the received signal vectors assigned with the weighting coefficients by the 
weighting coefficient evaluation/control part 19G in Figs. 9 and 10 for controlling the influence of the similarity error dif- 
ference vector Af (k). This embodiment is identical in construction with the Fig. 1 1 embodiment with respect to the other 
remaining points, of which no description will be repeated. 

EFFECT OF THE INVENTION 

This invention method can be used for echo cancellation in the realization of a teleconference system of highly real- 
istic presence which permits transmission of acousto-spatial information between two points by the use of a mufti-chan- 
nel transmission system and terminal equipment provided with multi-channel pickup and receive systems. 

For the sake of brevity, consider a stereo teleconference system which connects two points via a two-channel trans- 
mission system and uses two-channel pickup and receive systems as shown in Fig. 4. For example, when a plurality of 
speakers speak in their seats at the point A, stereo speech signals which are picked up by two microphones bear a 
cross-correlation therebetween dependent on the positional relationship between the speakers and the microphones. 
When these speech signals are reproduced at the point B using the conventional echo canceller, the echo estimation 
depends on the cross-correlation between the speech signals and hence is incorrect, allowing large echoes to return 
to the point A each time the speaker changes. In contrast to this, the echo cancellation method of the present invention 
is capable of lessening the influence of the cross-correlation between the stereo signals and quickly estimating the echo 
path, and hence suppresses echoes from increasing whenever the speaker changes. Fig. 13 is a graph showing the 
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results of computer simulations using, as reproduced signals, stereophonically picked up speech uttered by a speaker 
with his body or head fixed. The prior art method (a), a method of extracting a variation in the cross-correlation (b) pro- 
posed in the inventors' prior application (Japanese Pat. Appln. No. 50002/95), and this invention method (c) are com- 
pared in terms of the error vector between the combined estimated echo path vector generated in the echo path 

5 estimating part and the combined true echo path, with the echo path estimation starting time set at 0. An NLSM (Nor- 
malized Least Mean Squares) algorithm was used in the case of the conventional method and a second-order projec- 
tion algorithm was used in the case of the method by the extraction of a variation in the cross-correlation proposed in 
the prior application. In the case of this invention method, the adjustment vector was calculated by Eq. (107); the 
weighting coefficients yi. Vi. Tfe and y 2 were made time-varying in accordance with the echo return loss enhancement 

10 (ERLE), ^=/f 2 =/c 3 =^4=1.0, p 1= p* 1 =p 2 =p' 2 =2, An)=A< 2 >=A( 3 >=A< 4 >=A< 5 >=A< 6 >, and they were divided into four blocks and 
assigned with weights 1 .0, 0.5, 0.25 and 0.1 25. As is evident from Fig. 1 3, according to this invention method, the echo 
path error vector decreases faster than in the cases of the other methods and the vector itself is also smaller. 

Fig. 14 is a graph showing the influences of the weighting coefficients -ft and y 2 wi * n t ne coefficients yi and y 2 set 
^ Yi =Y2=0 in this invention method using Eq. (70). The curve (a) indicates the case where yi^yV*" 1 ° and the curve (b) 

75 the case where y 1 */ 2 !s0 - 5 - A comparison of these curves indicates that appropriate values of the weighting coefficients 
Y*1 and y 2 differ with the convergence of filter coefficients. Then, the values of the weighting coefficients y-| and y 2 were 
changed with ERLE, that is, ERLE was large the coefficients and y 2 were set small; in this case, the characteristic 
was improved as indicated by the curve (c). Further, the ES algorithm based on the exponential decay characteristic of 
the impulse response was used, in which case the curve (d) was obtained. This is considered to be due to the fact that 

20 since this invention method approximately utilizes the unknown input-output relationships expressed by Eqs. (55) and 
(57), the approximation accuracy is improved by the use of the statistical property of the impulse response. 

Fig. 1 5 shows the convergence characteristics of the echo path estimation which were obtained when this invention 
method (3-b) was used under the same conditions as in the case of Fig. 14 and the following coefficients were made 
time-invariant in Eq. (84). 

25 The curve (a) indicates the case where v 1 =v 2 =0, wj =w 2 =1 , Pi=p'i =P2=P 2-1 and |ut 1 =n 2 =0.5, the curve (b) the case 
where v 1= v 2 =1, w 1 =w 2 =1, p 1 =p' 1 =p 2 =p' 2 =8 and ^=^=0.05, the curve (c) the case where v 1 =v 2 =0 I w 1 =w 2 =1, 
p 1 =p' 1 =p 2 =p , 2 =8 and m=n 2 =0.05, the curve (d) the case where v 1 =v 2 =0, w 1 =w 2 =0, p 1 =p , 1 =p 2 =p' 2 =8 and ^^=0.05, 
and the curve (e) the case where v 1 =v 2 =1, w 1 =w 2 =0, p 1 =p' 1 =p 2 =p' 2 =8 and ^=^=0.05. As will be seen from Fig. 15, 
since this invention method (3-b) uses the weighting scheme of the method (1-b), the error obtained concerning the 

30 approximated input-output relationship can be evaluated excepting therefrom the error obtained concerning the observ- 
able input-output relationship or a redundant component as in the case of the curve (e) in Fig. 15; hence, good results 
can be obtained without varying the weighting coefficients with time as in the cases of Figs. 13 and 14. 

Example of Application 

35 

Other than the method according to which at a terminal provided with a stereo receiving system, two-channel 
stereo signals picked up at the other end are received and reconstructed intact, there is proposed a method for multi- 
point teleconference by which the received signal for each point is freely subjected to sound image localization at the 
receiving side to provide a comfortable receiving environment. The method and apparatus according to the present 

40 invention are also applicable to such multi-point teleconference terminals. Fig. 16 illustrates the configuration of a four- 
point teleconference system. At each point the pickup system is one-channel (monaural). Now, the teleconference sys- 
tem will be described in connection with the point D. Let it be assumed that at the point D received signals from the 
points A, B and C are subjected to sound image localization so that the signals are localized at the right, center and left 
with respect to the point d, respectively, by which new two-channel stereo reproduced signals are generated for two- 

45 channel stereo reproduction. In this instance, a response y 1 (k) to the two-channel received signals x^k) and x 2 (k) at 
some point is given as follows: 

y , (k) = h J n (k) x j (k) + hj, (k) x 2 (k) (108) 

50 

By applying the echo path similarity error vector f^k) between hTi (k) and hji (k). the following equation is obtained: 
h[, (k) - hj, (k) = f , (k) (109) 

55 

Then, the response y^fk) which is obtained when the reproducing channels of the received signals x1(k) and x2(k) are 
exchanged is given as follows: 



27 



BNSDCOD: <EP 0766446A2_I_> 



EP0 766 446 A2 



y'i 00 = h T lt (k) x 2 (k) + hj x (k) x , (k) 

= y, - tj (k)x, (k) + f|(k)x 2 (k) (110) 



By formulating simultaneous equations based on Eqs. (108) and (110), it is possible to obtain an estimated echo path 
vector adjustment equation according to this invention method. 

Generally speaking, in the application of the conventional echo cancellation method to a teleconference system 
composed of a multi-receive-channel system and a pickup system of one or more channels, the echo path estimation 
is not correctly made when the received signals of the respective channels have a high cross-correlation; therefore, the 
echo increases upon each variation in the cross-correlation between the received signals. This invention method uti- 
lizes, in addition to the input-output relationships based on multi-channel received signals bearing a fixed cross-corre- 
lation, approximated input-output relationships based on multi-channel signals bearing a cross-correlation different 
from the above-mentioned one. That is, an unknown output is approximated which ought to be produced by each micro- 
phone that picks up acoustic signals reproduced from channels different from their originals when some or all of the 
multi-channel received signals are exchanged. Since the echo path estimation is made by solving simultaneous equa- 
tions concerning these input-output relationships, its solution does not become indefinite, and hence such problems as 
described above can be reduced. 

It will be apparent that many modifications and variations may be effected without departing from the scope of the 
novel concepts of the present invention. 

Claims 

1 . A multi-channel acoustic echo cancellation method comprising the steps of: 

(a) radiating received signals of a plurality of channels as acoustic signals by a plurality of loudspeakers 
respectively corresponding thereto; 

(b) picking said acoustic signals from said plurality of loudspeakers up by each microphone after propagating 
over respective echo paths to obtain an observable echo; 

(c) storing said received signals of said plurality of channels for predetermined periods of time and forming 
received signal vectors by said stored received signals for each channel; 

(d) combining said received signal vectors in all the channels into observable combined received signal vec- 
tors; 

(e) providing said combined received signal vectors to estimated echo paths having combined estimated echo 
path vectors which converge to combined vectors of the echo path vectors represented by impulse responses 
of the respective echo paths, whereby is generated an echo replica simulating said observable echo, said com- 
bined received signal vectors and said corresponding echo corresponding to said observable input-output rela- 
tionships of said plurality of echo paths; 

(f) subtracting said echo replica from said echo to obtain a residual echo; 

(g) calculating an approximated echo replica in the case where combined exchanged received signal vectors, 
obtained by exchanging at least two received signals of said plurality of channels, are provided to said esti- 
mated echo paths; 

(h) approximating an echo which ought to be obtained by each microphone when said received signals 
exchanged as in step (g) propagate thereto over said plurality of echo paths; 

(i) substracting said approximated echo replica from said approximated echo to obtain an approximated resid- 
ual echo; 

(j) evaluating observable input-output relationships representing the relationships between said observed com- 
bined received signal vectors and said corresponding observable residual echo and approximated input-output 
relationships representing the relationships between said combined exchanged received signal vectors and 
said approximated residual echo and obtaining said adjustment vector based on the evaluation; and 
(k) adjusting said estimated echo path vector by said adjustment vector. 

2. The method of claim 1 , wherein said step (j) includes a step of weighting at least one of said approximated input- 
output relationships and said observable input-output relationships in their evaluation. 

3. The method of claim 2, wherein said weighting step includes a step of multiplying, by time-invariant or time-varying 
coefficients, residual echoes which are differences between echoes corresponding to the outputs of said approxi- 
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mated and observable input-output relationships and echo replicas which simulate them. 

4. The method of claim 2, wherein said weighting step includes a step of separating said approximated residual echo 
into a component correlated with said observable residual echo and other component and multiplying said compo- 

5 nents by time-invariant or time-varying coefficients independently of each other. 

5. The method of claim 4, further comprising a step of calculating said approximated input-output relationships 
through utilization of said actually observable known input-output relationships, said observable residual echo for 
use in the evaluation of said known input-output relationships and the similarity between said plurality of echo 

10 paths, and on the assumption that similar echo paths are formed between loudspeakers and microphones similar 
in such physical positional relationships as the distances between them and their directions or orientations, intro- 
ducing a difference in said similarity as an echo path similarity error vector, and calculating said estimated echo 
path adjustment vector by a projection algorithm through the use of said approximated input-output relationships, 
said observable input-output relationships and their past input-output relationships. 

15 

6. The method of claim 5, further comprising a step of introducing a weighting coefficient which makes it possible to 
control the influence of said echo path similarity error vector. 

7. The method of claim 2, 3, or 4, further comprising a step of determining, for each operation time, the value of said 
20 weighting coefficient through utilization of at least one of the ratio between said echo and said residual echo, the 

average power ratio between said echo and said residual echo, the absolute value of said residual echo and the 
average power of said residual echo. 

8. The method of claim 1 , further comprising a step of calculating said approximated input-output relationships 
25 through utilization of said actually observable known input-output relations, a residual error signal for use in the 

evaluation of said known input-output relationships and the similarity between said echo paths. 

9. The method of claim 2, further comprising a step of calculating said approximated input-output relationships 
through utilization of said actually observable known input-output relations, a residual error signal for use in the 

30 evaluation of said known input-output relationships and the similarity between said echo paths. 

10. The method of claim 4, further comprising a step of calculating at least one of the ratio between said echo and said 
residual echo, the average power ratio between said echo and said residual echo, the absolute value of said resid- 
ual echo and the average power of said residual echo, determining the state of convergence of said residual echo 

35 on the basis of said calculated value, and when the state of convergence of said residual echo is bad, setting the 
weighting coefficient for said correlated component at a predetermined value except 0 and the weighting coefficient 
for the other remaining component at 0, and when the state of convergence is good, setting said weighting coeffi- 
cients for both of said components at predetermined values including 0. 

40 11. The method of claim 8, further comprising a step of calculating said estimated echo path adjustment vector by 
using said approximated input-output relationships, said observable input-output relationships and their past input- 
output relationships. 

12. The method of claim 1 1 , further comprising a step of using said past input-output relationships through utilization 
45 of a projection algorithm. 

13. The method of claim 8, 9, or 11, further comprising a step of utilizing said echo path similarity on the assumption 
that similar echo paths are formed between loudspeakers and microphones similar in such physical positional rela- 
tionships as the distances between said loudspeaker and said microphones and their directions or orientations. 

50 

14. The method of claim 4, 8, 9, or 1 1 , further comprising a step of introducing the difference in said echo path similarity 
as an echo path similarity error on the assumption that similar echo paths are formed between loudspeakers and 
microphones similar in such physical positional relationships as the distances between them and their directions or 
orientations. 

55 

15. The method of claim 14, further comprising a step of introducing a weighting coefficient which makes it possible to 
control the influence of said echo path similarity error vector. 

16. The method of claim 8, 9, or 11 , further comprising a step of applying an exponentially weighted step-size algorithm 
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which provides a different adjusted weighting coefficient for each tap on the basis of the exponential decay property 
of impulse responses of said echo paths in the calculation of said estimated echo adjustment vector. 

17. A multi-channel acoustic echo canceller comprising: 

a plurality of loudspeakers for radiating received signals in a plurality of channels into acoustic signals and for 
outputting them; 

at least one microphone connected to at least one transmission channel, acoustic paths for said acoustic sig- 
nals from said plurality of loudspeakers to said microphone forming echo paths and said acoustic signals 
picked up by said microphone and combined into an echo for input into said transmission channel; 
a received signal vector generating part for temporarily storing said received signals of said plurality of chan- 
nels and for generating each received signal vector; 

a vector combining part for combining said received signal vectors of said plurality of channels into combined 
received signal vectors; 

an echo replica generating part supplied with said combined received signal vectors and combined estimated 
echo path vectors simulating said combined echo path vectors obtained by combining echo path vectors rep- 
resenting impulse responses of said echo paths from said plurality of loudspeakers to said microphone, for out- 
putting an echo replica simulating said echo; 

a subtracter for subtracting said echo replica vector from said echo output from the microphone and for output- 
ting the difference as an observable residual echo; 

a vector permuting/combining part for generating combined rearranged received signal vectors obtained by 
combining said received signals of said plurality of channels after rearranging at least two received signals of 
said plurality of channels; and 

an echo path estimating part supplied with at least said combined received signal vectors and said observable 
residual echoes corresponding thereto, for obtaining approximated echo replica in the case of applying each 
of said combined received signal vectors to one of said estimated echo paths, for obtaining, as an approxi- 
mated echo by approximating the inputs into said plurality of echo paths, an unknown echo to be obtained from 
said microphone in the case of said received signals being exchanged, for subtracting said approximated echo 
replica from said approximated echo to obtain an approximated residual echo, for evaluating an observable 
input-output relationship representing the relation between said combined received signal vector and said 
observable residual echo corresponding thereto and an approximated input-output relationship representing 
said rearranged combined received signal vector and said approximated residual echo corresponding thereto, 
for obtaining said adjustment vector on the basis of the evaluation, for generating an estimated echo vector 
obtained by adjusting said estimated each path vector with said adjustment vector, for providing it to said echo 
replica generating part. 

18. The echo canceller of claim 17, wherein said echo path estimating part comprises: 

residual echo weightig means for weighting said observable residual echo and said approximated residual 
40 echo relative to each other; 

an adjustment vector calculating part for calculating said adjustment vector on the basis of the relationships 
between said combined received signal vector and said rearranged received signal vector and between said 
observable residual echo and said approximated residual echo; and 

an adaptive filter updating part for adjusting said estimated echo path vector by said adjustment vector and for 
45 providing said adjusted estimated echo path vector to said echo replica generating part. 

19. The echo canceller of claim 17, wherein said echo path estimating part further comprises: 

component separating part for separating said approximated residual echo into a component correlated with 
so said observable residual echo and other non-correlated component; and 

weighting means for weighting said correlated component and said non-correlated component relative to each 
other. 

20. The echo canceller of claim 19, wherein said echo path estimating means further comprises cross -correlation cal- 
55 culating part for calculating the cross-correlation of said rearranged received signal vector with said received signal 

vector and said component separating part comprises means for calculating the product of said cross-correlation 
calculated by said cross-correlation calculating part and said observable residual echo as said component of said 
approximated residual echo which is correlated with said observable residual echo. 
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21. The echo canceller of claim 18 or 19. wherein said echo path estimating part further comprises a weighting coeffi- 
cient control part for calculating, at each operation time, at least one of the ratio between said echo and said resid- 
ual echo, the average power ratio between said echo and said residual echo, the absolute value of said residual 
echo and the average power of said residual echo as an index representing the state of convergence of said 

5 observable residual echo and for controlling said weighting coefficients on the basis of said calculated value. 

22. The echo canceller of claim 18 or 19, wherein said echo path estimating part further comprises a similarity error 
weighting part for assigning said received signal vector with a weighting coefficient for controlling the influence on 
said residual echo by a similarity error difference vector which is a difference between a similarity error vector 

w between similar echo paths and a similarity error vector between said estimated echo paths corresponding to said 
similar echo paths. 

23. The echo canceller of claim 18 or 19, wherein said adjustment vector calculating part comprises a signal storage 
part for storing said received signal vectors, said rearranged received signal vectors and said residual echoes at a 

is predetermined number of previous points in time going back from the current time, and a simultaneous equations 
calculating part for obtaining said adjustment vector by solving simultaneous equations through utilization of the 
relationships among said received signal vectors, said rearranged received signal vectors and said residual echoes 
at said previous points in time from the current time and said adjustment vector. 

20 24. The echo canceller of claim 22, wherein said adjustment vector calculating part comprises a signal storage part for 
storing said received signal vectors, said rearranged received signal vectors and said residual echoes at a prede- 
termined number of previous points in time going back from the current time, and a simultaneous equations calcu- 
lating part for obtaining said adjustment vector by solving simultaneous equations through utilization of the 
relationships among said received signal vectors, said rearranged received signal vectors and said residual echoes 

25 at said predetermined number of previous points going back from said current time, said adjustment vector and 
said similarity error difference vector. 

25. The echo canceller of claim 23 or 24, wherein said adjustment vector calculating part further comprises an expo- 
nentially weighting means for weighting said received signal vectors and said rearranged received signal vectors at 
30 said predetermined number of previous points going back from said current time by exponential decay coefficient 
vectors of the same numbers of elements as those of said received signal vectors and said rearranged received 
signal vectors, and said simultaneous equations calculating part uses an exponentially weighted step-size algo- 
rithm to calculate said adjustment vector. 

35 
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(54) Method and apparatus for multi-channel acoustic echo cancellation 

(57) In a multi-channel acoustic echo cancellation, 
received signals in a plurality of channels are radiated 
as acoustic signals by a plurality of loudspeakers, 
received signal vectors in these channels are combined 
into a combined vector and a rearranged received sig- 
nal vector in the case of at least two channels being 
exchanged is generated. By inputting the combined 
received signal vector into an echo replica generating 
part which simulates echo paths from the loudspeakers 
to at least one microphone, an echo replica is gener- 
ated. The echo replica is subtracted from an echo out- 
put from the microphone to obtain a residual echo. 
Based on the relationship between the received signal 
vector and the corresponding residual echo and 
between the rearranged received signal vector and the 
corresponding approximated residual echo, an adjust- 
ment vector is obtained which is used to adjust the esti- 
mated echo path vector representing an impulse 
response of the echo replica generating part. 
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